package offer2

/**
原题链接:
https://leetcode.cn/problems/er-jin-zhi-zhong-1de-ge-shu-lcof/

B站小美算法讲解
剑指 Offer 15. 二进制中1的个数

编写一个函数，输入是一个无符号整数（以二进制串的形式），返回其二进制表达式中数字位数为 '1' 的个数（也被称为 汉明重量).）。

提示：
请注意，在某些语言（如 Java）中，没有无符号整数类型。
在这种情况下，输入和输出都将被指定为有符号整数类型，并且不应影响您的实现，
因为无论整数是有符号的还是无符号的，其内部的二进制表示形式都是相同的。

在 Java 中，编译器使用 二进制补码 记法来表示有符号整数。因此，在上面的 示例 3 中，输入表示有符号整数 -3。

示例 1：
输入：n = 11 (控制台输入 00000000000000000000000000001011)
*/

func NumberOf1(n int) int {
	// write code here
	if n == 0 {
		return 0
	}
	count := 0

	for i := 0; i < 32; i++ {
		if (1 << i & n) > 0 {
			count++
		}
	}

	return count
}
